package com.jacklei.ch11;

import java.util.Arrays;
import java.util.Comparator;
import java.util.PriorityQueue;

/*
* 有一堆石头，每块石头的重量都是正整数。

每一回合，从中选出两块 最重的 石头，然后将它们一起粉碎。假设石头的重量分别为 x 和 y，且 x <= y。那么粉碎的可能结果如下：

如果 x == y，那么两块石头都会被完全粉碎；
如果 x != y，那么重量为 x 的石头将会完全粉碎，而重量为 y 的石头新重量为 y-x。
最后，最多只会剩下一块石头。返回此石头的重量。如果没有石头剩下，就返回 0。

 

示例：

输入：[2,7,4,1,8,1]
输出：1
解释：
先选出 7 和 8，得到 1，所以数组转换为 [2,4,1,1,1]，
再选出 2 和 4，得到 2，所以数组转换为 [2,1,1,1]，
接着是 2 和 1，得到 1，所以数组转换为 [1,1,1]，
最后选出 1 和 1，得到 0，最终数组转换为 [1]，这就是最后剩下那块石头的重量。
 

提示：

1 <= stones.length <= 30
1 <= stones[i] <= 1000

来源：力扣（LeetCode）
链接：https://leetcode.cn/problems/last-stone-weight
著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。*/
public class LastStoneWeight {
    public static void main(String[] args) {
        LastStoneWeight l = new LastStoneWeight();
        System.out.println(l.lastStoneWeight(new int[]{2, 7, 4, 1, 8, 1}));
    }
    public int lastStoneWeight(int[] stones) {
        Arrays.sort(stones);
        for (int i = 0; i < stones.length/2; i++) {
            stones[i] = stones[i] ^ stones[stones.length-1 -i];
            stones[stones.length-1 -i] = stones[i] ^ stones[stones.length-1 -i];
            stones[i] = stones[i] ^ stones[stones.length-1 -i];
        }

    return stoneWeight(stones);
    }
    public int stoneWeight(int[] stones){
        if(stones.length == 0) return 0;
        if(stones.length == 1) return stones[0];
        int stone1 = stones[0];
        int stone2 = stones[1];
        stones[1] = Math.abs(stone1 - stone2);
        return lastStoneWeight(Arrays.copyOfRange(stones,1,stones.length));
    }
    public int lastStoneWeight1(int[] stones) {
        PriorityQueue<Integer> queue = new PriorityQueue<>((a, b) -> b - a);
        for (int stone : stones) {
            queue.add(stone);
        }
        while (queue.size()>1){
            Integer poll = queue.poll();
            Integer poll1 = queue.poll();
            if(poll > poll1){
                queue.offer(poll - poll1);
            }
        }
        return queue.isEmpty() ? 0 : queue.poll();
    }
}
